$(function() {
    var layer = layui.layer
    var form = layui.form
    initCate()
        //初始化富文本编辑器
    initEditor()

    //初始化文章分类的方法
    function initCate() {
        $.ajax({
            method: 'GET',
            url: '/my/article/cates',
            success: function(res) {
                if (res.status !== 0) {
                    return layer.msg('获取分类数据失败！')
                }
                //调用模版
                var htmlStr = template('tpl-cate', res)
                $('[name=cate_id]').html(htmlStr)
                    //通知layui重新渲染表单区域
                form.render()

            }
        })
    }

    // 初始化图片剪裁
    var $image = $('#image')

    // 剪裁选项
    var options = {
        aspectRatio: 400 / 200,
        preview: '.img-preview'
    }

    // 初始化剪裁区域
    $image.cropper(options)

    // 为选择封面的按钮，绑定点击事件
    $('#btnChooseImage').on('click', function() {
        $('#coverFile').click()
    })

    $('#coverFile').on('change', function(e) {
            e.preventDefault()
            var fileList = e.target.files
                // 判断是否选择了文件
            console.log(e);

            if (fileList.length === 0) {
                return '请选择要上传的图片'
            }
            var imgURL = URL.createObjectURL(fileList[0])
            $image
                .cropper('destroy') // 销毁之前的裁剪区域
                .attr('src', imgURL) // 重新设置图片路径
                .cropper(options) // 重新初始化裁剪区图片
        })
        //定义文章发布状态
    var art_state = '已发布'
    $('#btnSave2').on('click', function() {
        art_state = '草稿'
    })

    $('#form-pub').on('submit', function(e) {
        e.preventDefault()
            //$(this)[0]转换为原生的dom对象
        var fd = new FormData($(this)[0])
        fd.append('state', art_state)
        $image.cropper('getCroppedCanvas', {
            width: 400,
            height: 280
        }).toBlob(function(blob) {
            // 将画布上的内容，转化为文件对象
            // 得到文件对象，存储到fd 中
            fd.append('cover_img', blob)
            publishArticle(fd)
        })
    })

    function publishArticle(dataFd) {
        $.ajax({
            method: 'POST',
            url: '/my/article/add',
            data: dataFd,
            contentType: false,
            processData: false,
            success: function(res) {
                if (res.status !== 0) {
                    return layer.msg('发表文章失败!')
                }
                layer.msg('发表文章成功')
                location.href = './art_list.html'
            }
        })
    }
})